#!/bin/sh
# PCP QA Test No. 1419
# exercise the -v N option to pmlogger to volume switch after N samples
#
# PCP_ARCHIVE_VERSION V3 variant, see 136 for the V2 variant.
#
# Copyright (c) 1995-2002 Silicon Graphics, Inc.  All Rights Reserved.
#

seq=`basename $0`
echo "QA output created by $seq"

# get standard filters
. ./common.product
. ./common.filter
. ./common.check

trap "$sudo rm -f $tmp.*; exit" 0 1 2 3 15

_do_ls()
{
    # hostname length affects the pmcd.pmlogger metrics in volume 0
    # such that we need to cater for an extra large range of possible
    # volume sizes in the first volume for long-hostname-hosts, ditto
    # for the epilogue and the last volume (4)
    #
    $PCP_AWK_PROG '
/Cannot/	{ print; next }
$9 ~ /\.[04]$/	{ if (1544 <= $5 && $5 <= 1660)
		    print $9," OK in range 1544-1660 bytes"
		  else
		    print $9,$5," not in range 1544-1660 bytes"
		  next
		}
		{ if (1360 <= $5 && $5 <= 1370)
		    print $9," OK in range 1360-1370 bytes"
		  else
		    print $9,$5," not in range 1360-1370 bytes"
		  next
		}' \
    | sed -e "s;$tmp;MYLOG;"
}

_do_time()
{
    tstamp=`wc -l <$tmp.sed | sed -e 's/  *//g'`
    tstamp=`expr $tstamp - 2`
    sed >$tmp.tmp \
	-e "s;$tmp;MYLOG;" \
	-e 's/from host .*/from host LOCALHOST/' \
    # end
    sed -n <$tmp.tmp \
      -e 's/.*\([0-9][0-9]:[0-9][0-9]:[0-9][0-9].[0-9][0-9]*[0-9]\).*/\1/p' \
    | sort -u \
    | while read time
    do
    	if grep $time $tmp.sed >/dev/null
	then
	    :
	else
	    echo "s/$time/TIMESTAMP-$tstamp/g" >>$tmp.sed
	    tstamp=`expr $tstamp + 1`
	fi
    done

    sed -f $tmp.sed $tmp.tmp
}

# real QA test starts here
echo 's/ [A-Z][a-z][a-z] [A-Z][a-z][a-z] .. / month-day /g' >$tmp.sed
echo 's/ [12][0-9][0-9][0-9]$/ year/' >>$tmp.sed

_start_up_pmlogger -V 3 -r -s 50 -v 10 -L -c /dev/null -l $tmp.log $tmp >$tmp.err 2>&1
pmsleep 1.1

pmlc <<End-of-File
connect $pid
log mandatory on 100 msec { sampledso.milliseconds }
End-of-File

_wait_pmlogger_end $pid || _exit 1

cat $tmp.log >>$seq_full

# write a fixed length hostname into log label (for dumplog determinism)
$sudo pmloglabel -h qahost $tmp

LC_TIME=POSIX ls -l $tmp.? | tee -a $seq_full | _do_ls

echo
pmdumplog -t $tmp | _do_time \
| $PCP_AWK_PROG '
$1 ~ /TIMESTAMP/ && NF == 4	{ print $1 "            " $2 "       OFFSET       OFFSET"; next }
				{ print }'

echo
echo "=== samples, expect 50 + 1 for prologue + 1 for epilogue ==="
pmdumplog -m $tmp | sed -n '/^[0-9]/p' | wc -l | sed -e 's/  *//g'

# diagnostic output only (-> .full)
#
echo "Label ..." >>$seq_full
pmdumplog -L $tmp >>$seq_full
echo >>$seq_full
echo "Selected pmResults ..." >>$seq_full
pmdumplog -m $tmp \
| $PCP_AWK_PROG >>$seq_full '
BEGIN		{ nrec = 0; want = 0 }
/^[0-9]/	{ nrec++ }
want == 0	{ if (nrec <= 2	|| nrec > 50) {
		    want = 1
		    print "Record",nrec
		  }
		}
want == 1	{ print }
NF == 0		{ want = 0 }'
